# Vitis HLS 2021.2 Tool Flow

### Lab1 z1

### Введение

В лабораторной работе показаны принципы This lab introduces how to perform basic actions using the Vitis™ High-Level Synthesis (HLS) tool design flow.

This lab should take approximately 45 minutes.

## **Objectives**

After completing this lab, you will be able to:

- Create a new project in the Vitis HLS tool GUI
- Simulate a C design by using a self-checking test bench
- Synthesize the design
- Perform design analysis using the Analysis Perspective view
- Perform co-simulation on a generated RTL design by using a provided C test bench
- Implement the design

### Introduction

This lab provides an introduction to the major features of the Vitis™ High-Level Synthesis (HLS) tool GUI flow. You will use the Vitis HLS tool in GUI mode to create a project. You will also simulate, synthesize, and implement the provided design.

In this lab, you will be using a C design to implement a discrete cosine transformation (DCT). The function implements a 2D DCT algorithm by first processing each row of the input array via a 1D DCT, then processing the columns of the resulting array through the same 1D DCT. It calls the *read\_data*, *dct\_2d*, and *write\_data* functions.

The *read\_data* function is defined at line 54 and consists of two loops: *RD\_Loop\_Row* and *RD\_Loop\_Col*. The *write\_data* function is defined at line 66 and consists of two loops to perform writing the result. The *dct\_2d* function, defined at line 23, calls the *dct\_1d* function and performs transpose.

Finally, the *dct\_1d* function, defined at line 4, uses *dct\_coeff\_table* and performs the required function by implementing a basic iterative form of the 1D Type-II DCT algorithm.

The following figure shows the function hierarchy on the left-hand side, the loops in the order they are executed, and the flow of data on the right-hand side.



Figure 1-1: Design Hierarchy and Dataflow

### **Understanding the Lab Environment**

The labs and demos provided can be successfully executed in the Windows environment or a native Linux environment as well.

**Note**: The working folder for the lab1\_z0 is C:\Xilinx\_trn\HLS2023\lab1\_z0 in the Windows environment.

## **General Flow**



# **Creating a Vitis HLS Tool Project**

Step 1

In this step, you will launch the Vitis HLS tool GUI and create a new project for the provided C-based discrete cosine transformation (DCT) design.

There are a number of ways to launch the Vitis HLS tool. The two most popular mechanisms are shown here.

#### 1-1. Launch the Vitis HLS tool.

### 1-1-1. [Windows 10 users:] Select Start > Xilinx Design Tools > Vitis HLS 2021.2.



Figure 1-2: Launching the Vitis HLS Tool

You can also double-click the **Vitis HLS** shortcut icon ( from the Windows or Linux desktop or taskbar.

[Linux users]: Click the Vitis HLS ( ) icon from the taskbar to launch the tool.

The Vitis HLS tool opens to the Welcome window. From the Welcome window, you can create a new project, open examples, and access documentation and examples.



Figure 1-3: Vitis HLS Welcome Page

Here you will create a new Vitis HLS tool project from scratch.

## 1-2. Create a Vitis HLS tool project named dct\_prj.

1-2-1. Click **Create Project** from the Welcome Page.



Figure 1-4: Creating a New Vitis HLS Tool Project

The Project Configuration dialog box asks for a project name and location.

- 1-2-2. Enter **dct\_prj** in the Project name field (1).
- 1-2-3. Enter C:\Xilinx\_trn\HLS2023\lab1\_z0 in the Location field (2).

You can also browse to the desired path.



- 1-2-4. Click **Next** (3).
- 1-3. The Add/Remove Files dialog box opens. Here you will be invited to add existing files or create new sources.
- 1-3-1. Click Add Files.
- 1-3-2. Browse to C:\Xilinx trn\HLS2023\lab1 z0\source.
- 1-3-3. Select **dct.c**.

The Vitis HLS tool automatically adds the working directory (project directory) and any directory that contains C files added to the project to the search path. Hence, header files that reside in these directories are automatically included in the project (no need to explicitly specify them). You must specify the path to all other header files (if any) by clicking **Edit CFLAGS**.

1-3-4. Click **OK** to add these files.

**Note:** If do not have existing files at this moment and you want to create new ones, click **New File**.

Note also that you can add compiler directives specific to each entry at this point.

1-3-5. Click **Browse** next to the Top Function field.

The Select Top function dialog box opens, which lists all the functions available from the specified source files.

1-3-6. Select **dct (dct.c)** from the list and click **OK**.

**Note:** You can also manually enter the name of the top function in the Top Function field.

In any C program, the top-level function is called main(). In the Vitis HLS tool design flow, you can specify any sub-function below main() as the top-level function for synthesis. You cannot synthesize the top-level function main().

The following are additional rules:

- o Only one function is allowed as the top-level function for synthesis.
- Any sub-functions in the hierarchy under the top-level function for synthesis are also synthesized.
- If you want to synthesize functions that are not in the hierarchy under the top-level function for synthesis, you must merge the functions into a single top-level function for synthesis.



Figure 1-5: Adding Files to a New Vitis HLS Project

#### 1-3-7. Click **Next**.

1-4. Add any existing test bench files.

If you have (or want) any test bench files, they can be entered here. Sometimes the test bench is built into the synthesizable file.

- 1-4-1. Click Add Files.
- 1-4-2. Navigate to C:\Xilinx\_trn\HLS2023\lab1\_z0\source.
- 1-4-3. Select dct\_test.c, in.dat, out.golden.dat.
- 1-4-4. Click **Open** to add these files.
- 1-4-5. Click **Next**.

1-5. Finally, it is time to specify some of the physical parameters of the design.

By default, solution 1 is populated in the Solution Name field. No changes are required.

1-5-1. Set the clock period to **10**.

You can leave the Uncertainty field blank.

1-5-2. Click the **Browse** (...) icon to select a part or board.



Figure 1-6: Locating the Board Browse Button

- 1-5-3. Click **Boards** as shown below.
- 1-5-4. Enter **ZYNQ UltraScale+** in the Search field.



Figure 1-7: Filtering to Quickly Locate Target Platforms

- 1-5-5. Select ZYNQ UltraScale+ ZCU104 Evaluation Board from the list.
- 1-5-6. Click **OK** to select the board.
- 1-5-7. Make sure that **Vivado IP Flow Target** is selected from the drop-down list under **Flow Target** field.
- 1-5-8. Click Finish.

You will see the created project in the Explorer tab.



Figure 1-8: Vitis HLS with Newly Created Project

The Vitis HLS tool GUI consists of various panes to proceed with the development work.

- In the upper left-hand side, the Explorer view lets you navigate through the project hierarchy. A similar hierarchy exists in the project directory on the disk. You can expand various sub-folders to see the entries under each sub-folder. The Source folder consists of source files associated with the project, and the Test Bench folder consists of test bench files associated with the project.
- In the center, the Information area displays report summaries and open files. Files can be opened by double-clicking them in the Explorer view.
- At the bottom, the Console view displays the output when the Vitis HLS tool is running synthesis or simulation.
- In the lower left-hand side, the Flow Navigator view provides access to commands and processes to take your source code through simulation, synthesis, and exported output.
- Though not displayed by default, when source code is opened in the Information area, the Outline and Directive views are displayed on the right side and show information related to the hierarchy of the code.

## **Running C Simulation**

Step 2

After creating the project, the next step is to validate that the C function is correct before proceeding with synthesizing the design. In this step, you will validate the design by using the provided self-checking C test bench.

- 2-1. Become familiar with the provided source and test bench files.
- 2-1-1. Expand the **Source** folder in the Explorer pane.
- 2-1-2. Double-click dct.c to open the file.This will open the source file in the Information pane.
- 2-1-3. Review the code and data structures.
- 2-1-4. Expand the **Includes** > **C:\Xilinx\_trn\HLS2023\lab1\_z0\source** folder in the Explorer pane.



- 2-1-5. Double-click **dct.h** to open the header file.
- 2-1-6. Review the contents of the header file.
- 2-1-7. Expand the **Test Bench** folder in the Explorer pane.
- 2-1-8. Double-click **dct\_test.c** to open it in the Information pane.

This test bench is a self-checking test bench; i.e., the computed output is compared against a reference golden output and returns either pass or fail.

### 2-2. Simulate the Vitis HLS tool design.

### 2-2-1. Select **Project** > **Run C Simulation**.



Figure 1-9: Launching the C Simulation

You can also run C simulation from the Flow Navigator by clicking **Run C Simulation** under C SIMULATION.



Figure 1-10: Launching the C Simulation Using the Flow Navigator

The Run C Simulation dialog box opens.



Figure 1-11: C Simulation Dialog Box

Each of the options controls how simulation is run:

- o Launch Debugger: After compilation the debug perspective automatically opens for you to step through the code.
- Build Only: Compiles the source code and the test bench, but the simulation does not run. This option can be used to test the compilation process and resolve any issues with the build prior to running simulation.
- Clean Build: Removes any existing executable and object files before compiling the code.
- Optimizing Compile: By default the design is compiled with debug information enabled, allowing the compilation to be analyzed and debugged. The Optimizing Compile option uses a higher level of optimization effort when compiling the design, but does not add information required by the debugger. This increases the compile time but should reduce the simulation runtime.
- Enable Pre-Synthesis Control Flow Viewer: Generates the Pre-synthesis Control Flow report.
- o Input Arguments: Specify any inputs required by your test bench main() function.

#### 2-2-2. Select **Default Options (i.e. select nothing to run a C simulation)**.

#### 2-2-3. Click **OK**.

The simulation log will be displayed in the editor pane.

### 2-3. View the simulation report.

The information generated by the Vitis HLS tool can be found in two places, both described here.

The first is the Console window, which reports not only the output produced by the code being simulated, but all of the simulation engine messages as well.

The second is the simulation log, which provides only a few simulation engine messages and the simulated code output.

2-3-1. Select the **Console** tab in the lower portion of the tool's GUI.

You may need to scroll to view all the output produced by the simulation.

```
VitisHLS Console

INFO: [HLS 200-18] In directory ' | /solution1/csim/build' |
INFO: [APCC 202-3] Tap directory is /tmp/apcc_db_xilinx/ |
INFO: [APCC 202-3] Tap directory is /tmp/apcc db_xilinx/ |
INFO: [APCC 202-3] Tap directory is /tmp/apcc db_xilinx/ |
INFO: [HLS 200-18] For user 'xilinx' on host 'xilinx' (Linux_x86_64 version 5.3.0-28-generic) on Wed Jan 13 18:35:45 IST 2021 |
INFO: [HLS 200-18] for user 'xilinx' on host 'xilinx' (Linux_x86_64 version 5.3.0-28-generic) on Wed Jan 13 18:35:45 IST 2021 |
INFO: [HLS 200-18] for directory |
INFO: [HLS 200-18] In directory |
INFO: [APCC 202-3] Tap directory is /tmp/apcc_db_xilinx/ |
INFO: [SIM 211-1] [SIm done with 8 errors. |
INFO: [SIM 211-3] [SIm done with 8 errors. |
INFO: [SIM 211-3] [SIm shed Command csim_design CPU user time: 13.35 seconds. CPU system time: 8.52 seconds. Elapsed time: 13.38 seconds; current allocated memory: 181.335 MB. Finished C simulation.
```

Figure 1-12: Example Output After Simulation

The other location (the simulation log), described below, provides only a few simulation engine messages and the simulated code output.

Typically, this is opened after the simulation completes; however, if you need to access it after closing the log pane, here's how to access the simulation report.

2-3-2. Expand dct\_prj > solution1 > csim > report in the Explorer pane.

2-3-3. Double-click the log file name to open it in the editor pane.



Figure 1-13: Locating the Simulation Log File

You should see a "Results are good" message in the simulation log file and in the console area. If you do not see this message, ask for help from your instructor.

## **Synthesizing the Design**

Step 3

In this step, you will synthesize the design by using Vitis HLS tool defaults and analyze how many resources are utilized to implement the C design.

## 3-1. Synthesize the design.

3-1-1. Select **Solution** > **Run C Synthesis** > **Active Solution** or click the **C Synthesis** icon from the toolbar.



Figure 1-14: Launching Synthesis

You can also click **Run C Synthesis** under C SYNTHESIS from the Flow Navigator at the bottom.

- **3-1-2.** Make sure that the clock period is the same as your project settings.
- 3-1-3. Make sure that the **Part** here matches with the part number of the project.
- 3-1-4. Select Vivado IP Flow Target from the Flow Target drop-down list.



Figure 1-15: C Synthesis Dialog Box

3-1-5. Click **OK**.

This synthesizes the currently selected solution.

All solutions (or selected solutions) can be synthesized by using the drop-down menu next to the synthesis icon. You can synthesize all solutions or synthesize selected solutions in addition to the default.

You can also run C synthesis from the Flow Navigator by clicking **Run C Synthesis** under C SYNTHESIS. You can then select the desired part and flow target to run the synthesis.



Figure 1-16: Launching Synthesis Using the Flow Navigator

When synthesis completes, the **Synthesis Summary Report** will be displayed in the Information pane.



Figure 1-17: Synthesis Report [Example]

The **Synthesis Summary Report** report shows the timing, performance, and area estimates as well as estimated latency in the design.

- 3-1-6. Expand the **dct\_prj** > **solution1** > **syn** > **report** folder in the Explorer pane.
- 3-1-7. Double-click the dct\_csynth.rpt file to view the Synthesis Details Report.
- 3-1-8. Scroll to **Performance Estimates** and **Utilization Estimates** in the **Synthesis Details Report** to answer the following question.

#### **Question 1**

Write down the following details from the Synthesis report:

- Target\Estimated clock periods:
- Worst case latency cycles/absolute (max):
- Number of BRAM\_18K:
- Number of DSP48E used:
- Number of FFs used:
- Number of LUTs used:

### 3-1-9. Select **Interface** > **Summary** in the Synthesis report.

The report also shows the top-level interface signals generated by the tools.



Figure 1-18: Generated Interface Signals

You can see that *ap\_clk* and *ap\_rst* and ap\_... are automatically added.

ap\_start, ap\_done, and ap\_idle are top-level signals used as handshaking signals to indicate

- when the design is able to accept the next computation command (ap\_idle),
- when the next computation is started (ap\_start),
- when the computation is completed (*ap\_done*).

Other signals are generated based on the design itself.

#### 3-1-10. Select the **Console** tab.

The Synthesis log is available in the Vitis HLS Console.

Note that when the *solution1* > *syn* folder is expanded in the Explorer view, it will show the *report*, *verilog*, and *vhdl* sub-folders under which the report files and generated source files (VHDL, Verilog, header, and cpp) are available. Double-clicking any of these entries will open the corresponding file in the Information pane.

Also, note that the target design has hierarchical functions, and reports corresponding to lower-level functions are also created.

By default, the report for the top-level function is displayed in the Information pane once synthesis is completed.

## **Analyzing the Design Using the Generated Reports**

Step 4

After synthesis completes, the Vitis HLS tool automatically creates another synthesis reports to help you understand and analyze the performance of the implementation.

These reports include the **Schedule Viewer**, **Function Call Graph** and **Dataflow Viewer**.

You can view these reports from the Flow Navigator in the Vitis HLS tool IDE.

- **Schedule Viewer**: Shows each operation and control step of the function and the clock cycle that it executes in.
- **Dataflow Viewer**: Shows the dataflow structure inferred by the tool, allowing you to inspect the channels (FIFO/PIPO) and examine the effect of channel depth on performance.
- o **Function Call Graph Viewer**: Displays your full design after C synthesis or C/RTL cosimulation to show the throughput of the design in terms of latency and initiation interval (II).

By default, the Schedule Viewer is displayed. It provides both a tabular and graphical view of the design performance and resources.

## 4-1. Switch to the Analysis perspective and understand the design behavior.

4-1-1. Select **Solution** > **Open Schedule Viewer** to open the Schedule Viewer.

You can also open the Schedule Viewer from the Flow Navigator by expanding the Reports & Viewers section and clicking **Schedule Viewer**.

Along with Schedule Viewer, you also get the following windows:

- Module Hierarchy: Shows the function hierarchy and the performance characteristics of the current hierarchy.
- Modules/Loops: Shows additional performance and resource metrics for each function/loop in the Modules/Loops table under the report.
- Performance Profile: Shows the loops from the top-level function without any performance information.
- Resource Profile: Shows the resource usage of different elements of the synthesized function
- Properties view: Shows the properties of the currently selected control step or operation in the Schedule Viewer.

The **Module Hierarchy** pane provides an overview of the entire RTL design. It shows the resources and latency contribution for each block in the RTL hierarchy. This view directly indicates any II or timing violations. In case of timing violations, the hierarchy window will also show the total negative slack observed in a specific module.

Note that the module hierarchies are displayed unexpanded by default.



The **Schedule Viewer** provides a detailed view of the synthesized RTL, showing each operation and control step of the function, and the clock cycle that it executes in. It helps you to identify any loop dependencies that are preventing parallelism, timing violations, and data dependencies.

- The left vertical axis shows the names of operations and loops in the RTL hierarchy in topological order, implying that an operation on line **n** can only be driven by operations from a previous line and will only drive an operation in a later line.
- The top horizontal axis shows the clock cycles in consecutive order.
- The vertical dashed line in each clock cycle shows the reserved portion of the clock period due to clock uncertainty. This time is left by the tool for Vivado Design Suite back-end processes, like place and route.
- Each operation is shown as a gray box in the table. The box is horizontally sized according to the delay of the operation as a percentage of the total clock cycle. In case of function calls, the provided cycle information is equivalent to the operation latency.
- Multi-cycle operations are shown as gray boxes with a horizontal line through the center of the box.
- General operator data dependencies are also displayed as solid blue lines. The green dotted line indicates an inter-iteration data dependency. Memory dependencies are displayed using golden lines.
- In addition, lines of source code are associated with each operation in the Schedule Viewer report. Right-click the operation to use the Goto Source command to open the input source code associated with the operation.

## 4-2. Analyze the performance and resources of the dct module.

Notice that all the loops in the design are pipelined by default.

**4-2-1**. Select **dct** in the Module Hierarchy.



This pane shows the resources used at this level of hierarchy.

In this design, you can see that most of the resources are due to the instances—blocks that are instantiated inside this block.

As per the function selected in the Module Hierarchy tab, you are able to view Schedules and the resources used by that function.

4-2-2. Select **RD\_Loop\_Row\_RD\_Loop\_Col** in the **Module/Loops** pane and review the performance and resources used in this pane information.



Figure 1-19: Modules/Loops Pane (ZCU104)

This pane shows that this loop has a trip count of 64.

It also shows that the loop RD\_Loop\_Row takes 64 clock cycles to execute.

**4-2-3.** Select **RD\_Loop\_Row\_RD\_Loop\_Col** in the Module Hierarchy and expand the loop **RD\_Loop\_Row\_RD\_Loop\_Col** in the Schedule Viewer (solution1).



The information presented in the Schedule Viewer:

• The design starts in the 0 state.

- o It then starts to execute the logic in the loop **RD\_Loop\_Row\_RD\_Loop\_Col**.
- The loop executes over two states: 0, 1.

Within the loop **RD\_Loop\_Row\_RD\_Loop\_Col**, you can see that there are some adders; a two-cycle read operation, and a write operation.



### 4-2-4. Select add\_In61(+).

| Section | Module Hierarchy | Section | Secti

4-2-5. Right-click the highlighted box and select **Goto Source**.

Figure 1-20: Performance of the dct Loop Operation

You can see the source code for the operation.

4-2-6. Select RD\_Loop\_Row\_RD\_Loop\_Col in the Module Hierarchy and expand the loop WR\_Loop\_Row\_WR\_Loop\_Col loop in the Schedule Viewer (solution1)/. Then select add\_In73(+).

4-2-7. Right-click the highlighted box and select **Goto Source**.



Figure 1-21: Performance of WR\_Loop\_Row\_WR\_Loop\_Col

You can see that the write operation is implementing the writing of data into the buf array from the input array variable.

## **Performing C/RTL Co-simulation**

Step 5

Now that you have performed high-level synthesis on the C design, you will perform RTL cosimulation on the generated RTL using the C test bench.

Run C/RTL co-simulation, selecting Verilog and skipping VHDL. Verify that the simulation passes.

## 5-1. Cosimulate the Vitis HLS tool design.

### 5-1-1. Select Solution > Run C/RTL Cosimulation.



Figure 1-22: Launching from the Menu

You can also launch C/RTL Co-simulation from the Flow Navigator.



Figure 1-23: Launching Cosimulation from Flow Navigator



The Run C/RTL Co-simulation dialog box opens.

Figure 1-24: Co-simulation Dialog Box

The dialog box includes the following settings:

- Simulator: Choose from one of the supported HDL simulators in the Vivado Design Suite. The Vivado simulator is the default simulator.
- o Language: Specify the use of Verilog or VHDL as the output language for simulation.
- Setup Only: Create the required simulation files, but do not run the simulation. The simulation executable can be run from a command shell at a later time.
- Optimizing Compile: Enable optimization to improve the runtime performance, if possible, at the expense of compilation time.
- o Input Arguments: Specify any command-line arguments to the C test bench.
- Dump Trace: Specifies the level of trace file output written to the sim/Verilog or sim/VHDL directory of the current solution when the simulation executes. Options include:
  - all: Output all port and signal waveform data being saved to the trace file.
  - port: Output waveform trace data for the top-level ports only.
  - none: Do not output trace data.
- Random Stall: Applies a randomized stall for each data transmission.

### 5-1-2. Leave the default options (i.e. select nothing).

#### 5-1-3. Click **OK**.

This process will take a few minutes to complete.

After C/RTL cosimulation has been completed, the Cosimulation report will be accessible in the Information pane, including the latency information.

Also, in the Console tab, notice the "Results are Good" message that is displayed.

## 5-2. View the Cosimulation report.

The information generated by the Vitis HLS tool can be found in two places, both described here.

The first is the Console window, which reports not only the output produced by the code being simulated, but all of the simulation engine messages as well. The simulation log provides only a few simulation engine messages and the simulated code output.

5-2-1. Select the **Console** tab in the lower portion of the Vitis HLS tool GUI.

You may need to scroll to view all the output produced by the cosimulation.

```
Vide Transaction Progress: Completed Transaction 7 Total Transaction

### Inter-Transaction Progress: Completed Transaction 7 Total Transaction

#### Inter-Transaction Progress: Completed Transaction Progress: (Inter-Transaction Progress): Measured Letters / Linker Progress: Measured Letters / Linker Progress: (Inter-Transaction Progress: Completed Transaction Progress: (Inter-Transaction Progress: Completed Transaction Progress: (Inter-Transaction Progress: (Inter-Transactio
```

Figure 1-25: Example Output After a C/RTL Co-simulation

The other location, described below, provides only a few simulation engine messages and the simulated code output. Typically, this is opened after the simulation completes; however, if you need to access it after closing the log pane, here is how to access the simulation report.

5-2-2. Expand **dct\_prj** > **solution1** > **sim** > **report** in the Explorer pane.

5-2-3. Double-click the log file name to open it in the editor pane.



Figure 1-26: Locating the Co-simulation Log File

The Cosimulation Report in HTML format will be displayed in the main viewing area. You can also open the cosimulation report from Flow Navigator by expanding the **Reports & Viewers** section under the C/RTL COSIMULATION section.



Figure 1-27: Cosimulation Report - HTML